Sample based determination of network policy violations

ABSTRACT

Disclosed herein are a system, computer-readable medium, and method for enforcing network policies. Samples of data traveling through at least some nodes of a network are collected. It is determined whether a node violated a predefined network policy based on the samples.

BACKGROUND

Server virtualization has lead to the creation of large and dynamic data centers that provide great benefits for users and entities employing the services thereof. Such data centers may comprise a large number of interconnected network nodes. These nodes may contain one or more of a variety of network devices for relaying, combining, directing and otherwise handling information in its transit across the network. These devices may include edge switches, repeaters, routers, bridges, switches and hubs.

BRIEF DESCRIPTION OF THE DRAWINGS

FIG. 1 is a block diagram of an example system in accordance with aspects of the present disclosure.

FIG. 2 is a flow diagram of an example method in accordance with aspects of the present disclosure.

FIG. 3 is a working example in accordance with aspects of the present disclosure.

FIG. 4 is a further working example in accordance with aspects of the present disclosure.

DETAILED DESCRIPTION

As noted above, server virtualization has lead to the creation of large and dynamic data centers. However, the density and mobility of such data centers also create a new level of configuration and troubleshooting complexity. As greater numbers of virtualized servers consume the same physical resources, maintenance and proper configuration of these servers have become tedious and highly error prone. Furthermore, server virtualization allows workloads to be distributed dynamically, which exacerbates the configuration and troubleshooting problem. A trivial configuration error may cause a network to experience a significant decline in performance. Unfortunately, such configuration errors may take several weeks to diagnose.

In view of the foregoing, disclosed herein are a system, computer-readable medium, and method for enforcing network policies. In one example, samples of data traveling through at least some nodes of a network are collected. In a further example, it is determined whether a node violated a predefined network policy based on the samples. The system, computer-readable medium, and method disclosed in the present disclosure can reduce network troubleshooting from weeks to minutes. In this regard, the techniques herein can improve the profitability and customer goodwill of data centers managing these networks. The aspects, features and advantages of the present disclosure will be appreciated when considered with reference to the following description of examples and accompanying figures. The following description does not limit the application; rather, the scope of the disclosure is defined by the appended claims and equivalents.

FIG. 1 presents a schematic diagram of an illustrative computer apparatus 100 for executing the techniques disclosed herein. The computer apparatus 100 may include all the components normally used in connection with a computer. For example, it may have a keyboard and mouse and/or various other types of input devices such as pen-inputs, joysticks, buttons, touch screens, etc., as well as a display, which could include, for instance, a CRT, LCD, plasma screen monitor, TV, projector, etc. Computer apparatus 100 may also comprise a network interface (not shown) to communicate with other devices over a network.

The computer apparatus 100 may also contain a processor 110, which may be any number of well known processors, such as processors from Intel® Corporation. In another example, processor 110 may be an application specific integrated circuit (“ASIC”). Non-transitory computer readable medium (“CRM”) 112 may store instructions that may be retrieved and executed by processor 110. As will be discussed in more detail below, the instructions may include a network service sentinel 114 and a sensor 118. Furthermore, computer apparatus 100 may contain data that may be retrieved by processor 110, such as network policies 116. In one example, non-transitory CRM 112 may be used by or in connection with any instruction execution system that can fetch or obtain the logic from non-transitory CRM 112 and execute the instructions contained therein.

Non-transitory computer readable media may comprise any one of many physical media such as, for example, electronic, magnetic, optical, electromagnetic, or semiconductor media. More specific examples of suitable non-transitory computer-readable media include, but are not limited to, a portable magnetic computer diskette such as floppy diskettes or hard drives, a read-only memory (“ROM”), an erasable programmable read-only memory, a portable compact disc or other storage devices that may be coupled to computer apparatus 100 directly or indirectly. Alternatively, non-transitory CRM 112 may be a random access memory (“RAM”) device or may be divided into multiple memory segments organized as dual in-line memory modules (“DIMMs”). The non-transitory CRM 112 may also include any combination of one or more of the foregoing and/or other devices as well. While only one processor and one non-transitory CRM are shown in FIG. 1, computer apparatus 100 may actually comprise additional processors and memories that may or may not be stored within the same physical housing or location.

The instructions residing in non-transitory CRM 112 may comprise any set of instructions to be executed directly (such as machine code) or indirectly (such as scripts) by processor 110. In this regard, the terms “instructions,” “scripts,” and “applications” may be used interchangeably herein. The computer executable instructions may be stored in any computer language or format, such as in object code or modules of source code. Furthermore, it is understood that the instructions may be implemented in the form of hardware, software, or a combination of hardware and software and that the examples herein are merely illustrative.

In one example, a network comprising a plurality of interconnected nodes may have a plurality of sensors, such as sensor 118, to collect samples of data traveling through at least some nodes in the network. Network service sentinel 114 may determine whether a node violates a predefined network policy based on the samples and, if the node violates the predefined network policy, network service sentinel 114 may generate an alert containing an identification of the node and the predefined network policy being violated by the node.

Working examples of the system, method, and non-transitory computer-readable medium are shown in FIGS. 2-4. In particular, FIG. 2 illustrates a flow diagram of an example method 200 for enforcing network policies. FIGS. 3-4 each show a working example in accordance with the techniques disclosed herein. The actions shown in FIGS. 3-4 will be discussed below with regard to the flow diagram of FIG. 2.

As shown in block 202 of FIG. 2, samples from at least some nodes in a network may be read. Referring now to FIG. 3, a schematic diagram depicts various computing nodes 301, 303, 307 and 311 in a networked configuration. Such nodes may be interconnected via a network 302, which may be a LAN, WAN, the Internet, etc., which may be wired or wireless. Such networks and intervening nodes thereof may use various protocols including virtual private networks, local Ethernet networks, private networks using communication protocols proprietary to one or more companies, cellular and wireless networks, HTTP and SMTP, and various combinations of the foregoing. Although only a few nodes are depicted in FIG. 3, it should be appreciated that a typical system can include a large number of connected nodes and that FIG. 3 is merely illustrative.

Communication across network 302, including any intervening nodes, may be facilitated by any device capable of transmitting data to and from other computers. In the example of FIG. 3, edge switches 306 and 309 may be used to facilitate network traffic in and out of nodes 307 and 311. Although certain advantages may be obtained when information is transmitted or received with edge switches, the techniques disclosed herein are not limited to any particular manner of transmission of information. For example, in some aspects, the information may be sent via routers, routing switches, integrated access devices, multiplexers, or the like. Furthermore, any one of the nodes 301, 303, 307, and 311 may comprise a plurality of computers, such as a load balancing network, that exchange information with different nodes of a network for the purpose of receiving, processing and transmitting data. In this instance, the devices will typically still be at different nodes of the network than any of the computers comprising each node.

Sensors 305 and 308 may execute in edge switches 306 and 309 respectively to collect samples of network traffic entering and exiting nodes 307 and 311. In one example, sFlow® technology may be utilized to collect the network traffic samples and return those samples to network service sentinel 310 executing in node 301.

Referring back to FIG. 2, it may be determined whether a node in the network is violating a network policy, as shown in block 204. Referring back again to FIG. 3, sensors 305 and 308 may return samples of network traffic back to network service sentinel 310. In turn, network service sentinel 310 may evaluate the samples against network policy rules 312. In one example, the policy rules may be encoded with a policy language derived from the open-source SNORT® intrusion prevention service (“IPS”) signature language. IPS signature language may comprise an ordered set of rules containing regular expressions and Boolean logic against which the samples from sensors 305 and 308 may be evaluated against. Some network policies may include, but are not limited to, limitations on CRC errors or thresholds for unknown unicast and multicast MAC address induced switch flooding.

Referring back to FIG. 2, if it is determined that a network policy has been violated, an alert may be generated, as shown in block 206. Once again referring to FIG. 3, if network service sentinel 310 detects a policy violation, it may send an alert to network management server 304. In turn, network management server 304 may display the alert to an administrator.

Referring now to FIG. 4, a further example of enforcing network policies in accordance with the techniques presented herein is shown. This example shows network traffic samples being transmitted from sensor 305 to network service sentinel 310. In yet a further example, if it is determined that node 307 violates a network policy, a mirroring module 404 may be activated in edge switch 306. Mirroring module 404 may replicate real time data traveling through node 307 to network management server 304. Network management server 304 may display copies of these data packets on a monitor. This allows an administrator to view the real-time traffic and locate the network policy violations as they occur. In one example, the mirroring may be accomplished by re-encapsulating the traffic in a layer 3 tunnel and forwarding it to a specified IP address in the network.

Advantageously, the foregoing system, method, and non-transitory computer readable medium allow network policy violations to be detected automatically without tedious analyzes by network engineers that could take weeks to complete. Once the violations are automatically detected, the real time traffic may be forwarded to an administrator that allows the administrator to view the violation as it occurs. In this regard, data centers managing these networks can better meet the needs of their clients.

Although the disclosure herein has been described with reference to particular examples, it is to be understood that these examples are merely illustrative of the principles of the disclosure. It is therefore to be understood that numerous modifications may be made to the examples and that other arrangements may be devised without departing from the spirit and scope of the disclosure as defined by the appended claims. Furthermore, while particular processes are shown in a specific order in the appended drawings, such processes are not limited to any particular order unless such order is expressly set forth herein; rather, processes may be performed in a different order or concurrently and steps may be added or omitted. 

What is claimed is:
 1. A system comprising: a network comprising a plurality of interconnected nodes; a plurality of sensors which, if executed, instruct at least one processor to collect samples of data traveling through at least some nodes in the network; a network service sentinel comprising at least one hardware processor to: determine whether a node violates a predefined network policy based on data errors associated with the collected samples; and if the node violates the predefined network policy, generate an alert containing an identification of the node and the predefined network policy being violated by the node.
 2. The system of claim 1, further comprising a network management server which, if executed, instructs at least one processor to display the alert generated by the network service sentinel.
 3. The system of claim 1, wherein the errors comprise cyclic redundancy check (CRC) errors.
 4. The system of claim 1, wherein the predefined network policy comprises regular expressions and Boolean logic.
 5. The system of claim 1, wherein at least some of the plurality of nodes connects to the network using an edge switch.
 6. The system of claim 5, wherein at least one of the plurality of sensors executes in the edge switch.
 7. A non-transitory computer readable medium, comprising instructions therein which, if executed, instruct at least one processor to: read samples collected by a plurality of sensors distributed across a network of interconnected nodes, the samples comprising network data packets traveling through at least some nodes in the network; determine whether a node violates a predefined network policy based on the collected samples based at least in part on data errors associated with the collected samples; and if the node violates the predefined network policy, identify the node violating the predefined network policy and generate an alert to indicate the predefined network policy violated by the node.
 8. The non-transitory computer readable medium of claim 7, wherein the instructions therein, if executed, further instruct at least one processor to forward the alert to a network management server.
 9. The non-transitory computer readable medium of claim 8, wherein the instructions therein, if executed, further instruct at least one processor to replicate real time data packets traveling through the node to the network management server, when it is determined that the node violates the predefined network policy.
 10. The non-transitory computer readable medium of claim 7, wherein the predefined network policy comprises regular expressions and Boolean logic.
 11. The non-transitory computer readable medium of claim 7, wherein at least some of the plurality of nodes connects to the network using an edge switch.
 12. The non-transitory computer readable medium of claim 11, wherein at least one of the plurality of sensors executes in the edge switch.
 13. The non-transitory computer readable medium of claim 7, wherein the errors comprise cyclic redundancy check (CRC) errors.
 14. A method comprising: reading, using at least one processor, samples of network data packets traveling through at least some nodes of a network; determining, using at least one processor, whether a node violates a predefined network policy based on data errors associated with the read samples; and if the node violates the predefined network policy, displaying, using at least one processor, an alert identifying the node and indicating the predefined network policy violated by the node.
 15. The method of claim 14, wherein determining whether the node violates the predetermined network policy comprises determining whether the data errors exceed a limitation on cyclic redundancy check (CRC) errors.
 16. The method of claim 14, wherein the predefined network policy comprises regular expressions and Boolean logic.
 17. The method of claim 14, wherein at least some of the nodes connects to the network using an edge switch.
 18. The method of claim 17, wherein the edge switch comprises a sensor to collect the samples of network data. 